• Jump To … +
    main.js separate.js single.js web-apg-api.js main.js web-conv-api.js ast.js csv.js dangling-else.js display.js flags.js float.js limits.js main.js multiline-mode.js recursive.js replace.js rules.js split.js testonly.js trace.js udt.js unicode.js web-email.js word-boundaries.js main.js phone-number.js web-main.js web-phone-number.js main.js phone-number.js setup.js translate.js xml.js branch-fail-grammar.js main.js parent-mode-grammar.js setup.js universal-mode-grammar.js colors-app.js colors-callbacks.js colors.js main.js more-app.js more-setup.js more.js ast-callbacks.js bad-input.js basic.js ini-file.js main.js parser-callbacks.js setup.js trace.js anbncn.js and.js c-comment.js compound.js main.js nested.js not.js setup.js boundaries-grammar.js boundaries.js comment-grammar.js comment.js main.js negative-grammar.js negative.js positive-grammar.js positive.js setup.js main.js odata-grammar.js run.js setup.js area-code.js lookaround.js main.js phone-number.js setup.js simple.js all-operators.js default.js fancy-number.js limited-lines.js main.js select-operators.js select-rules.js setup.js main.js minimal.js parent-u.js parent.js phone-number.js setup.js stats.js trace.js universal-u.js universal.js callbacks.js grammar.js main.js parser.js writeHtml.js LICENSE.md README.md index.md
  • recursive.js

  • §
    /*  *************************************************************************************
     *   copyright: Copyright (c) 2021 Lowell D. Thomas, all rights reserved
     *     license: BSD-2-Clause (https://opensource.org/licenses/BSD-2-Clause)
     *   ********************************************************************************* */
  • §

    regexes often have trouble handling recursion. Matching pairs of parentheses is a classic recursion problem and is handled easily with apg parsers and by extension apg-exp. Here is a simple demonstration of matching paired parentheses and capturing all of the recursive matches.

    The parenthesis pairs are found and all values of the recursive rule R are retained.

    (function recursive() {
      try {
        const apgJs = require('apg-js');
        const { apgExp } = apgJs;
        let grammar = '';
        let txt;
        grammar += 'R     = (open text R text close) / (open text close)\n';
        grammar += 'open  = %d40               ; open paren "("\n';
        grammar += 'close = %d41               ; close paren ")"\n';
        grammar += 'text  = *(%d32-39/%d42-126); any characters but "()"\n';
  • §

    eslint-disable-next-line new-cap

        const exp = new apgExp(grammar, '');
        console.log();
        console.log('Demonstrate true recursion - matching paired parentheses and more.');
        console.log();
        const str = 'find the matched parentheses (down 1(down 2(down 3(the middle)up 3)up 2)up 1)';
        console.log('grammar:');
        console.log(exp.source);
        console.log();
        console.log(`     input: ${str}`);
        const result = exp.exec(str);
        if (result) {
          txt = result.toText();
          console.log(txt);
          txt = exp.toText();
          console.log(txt);
        } else {
          console.log('    result: null');
        }
      } catch (e) {
        console.log(`EXCEPTION: ${e.message}`);
      }
    })();